package src.dynamic_programming;

import java.util.HashMap;
import java.util.Map;

/**
 * @author starsea
 * @date 2024-09-16 17:03
 */

public class Test13 {
    public static void main(String[] args) {
        int[] arr={0,1};


    }
    public int findMaxLength(int[] nums) {
        int n=nums.length;
        if(n<2)
        {
            return 0;
        }
        int sum=0;
        int ret=0;
        Map<Integer,Integer> map=new HashMap<>();
        map.put(0,-1);
      for(int i=0;i<n;i++)
        {
            sum+=nums[i]==0?-1:1;
            if(map.containsKey(sum))
            {
                ret+=Math.max(ret,i-map.get(sum));
            }else
            {
                map.put(sum,i);
            }
        }
        return ret;
    }
}
